import java.util.HashMap;
import java.util.Map;

class Solution06 {
    public int subarraySum(int[] nums, int k) {
        int ret = 0;
        // 创建一个哈希表 前缀和 次数
        Map<Integer, Integer> hashMap = new HashMap<>();
        // 数据处理
        hashMap.put(0, 1);
        // 定义前缀和
        int sum = 0;
        for (int x : nums) {
            sum += x;
            ret += hashMap.getOrDefault(sum - k, 0);
            hashMap.put(sum, hashMap.getOrDefault(sum, 0) + 1);
        }
        return ret;
    }
}